package site.shihuan.helpdesk.im.dao;

import org.springframework.stereotype.Repository;
import site.shihuan.helpdesk.im.model.po.SvcHiMsgPO;

import java.util.List;

/**
 * 对话记录(SvcHiMsg)表数据库访问层
 *
 * @author 周世焕
 * @since 2021-03-04 12:57:19
 */
@Repository
public interface SvcHiMsgDao {

    /**
     * 通过主键查询单条数据
     *
     * @param msgId
     * @return 影响行数
     */
    SvcHiMsgPO selectByPrimaryKey(String msgId);

    /**
     * 新增数据
     *
     * @param svcHiMsg 实例对象
     * @return 影响行数
     */
    int insert(SvcHiMsgPO svcHiMsg);

    /**
     * 新增数据（可选字段）
     *
     * @param svcHiMsg 实例对象
     * @return 影响行数
     */
    int insertSelective(SvcHiMsgPO svcHiMsg);

    /**
     * 修改数据
     *
     * @param svcHiMsg 实例对象
     * @return 影响行数
     */
    int updateByPrimaryKey(SvcHiMsgPO svcHiMsg);

    /**
     * 修改数据(可选字段)
     *
     * @param svcHiMsg 实例对象
     * @return 影响行数
     */
    int updateByPrimaryKeySelective(SvcHiMsgPO svcHiMsg);

    /**
     * 通过主键删除数据
     *
     * @param msgId
     * @return 影响行数
     */
    int deleteByPrimaryKey(String msgId);

    /**
     * 查询聊天记录
     * @param tenantId
     * @param clerkId
     * @param visitorId
     * @param start
     * @param limit
     * @return
     */
    List<SvcHiMsgPO> selectClerkMsgBatch(String tenantId,String clerkId, String visitorId, int start, int limit);

    /**
     * 查询聊天记录
     * @param visitorId
     * @param tenantId
     * @param start
     * @param limit
     * @return
     */
    List<SvcHiMsgPO> selectVisitorMsgBatch(String visitorId, String tenantId, int start, int limit);

}
